c++ - Clang、std::next、libstdc++ 和 constexpr-ness
全部标签 给定:structIter{usingvalue_type=int;usingdifference_type=int;usingreference=int;usingpointer=int;usingiterator_category=int;};以下代码适用于libstc++,但无法针对libc++5.0.0进行编译:#include#includestatic_assert(std::is_same::iterator_category,Iter::iterator_category>::value,"");出现错误:error:nomembernamed'iterator_cat
我正在使用g++4.4.7编译一段非常古老的遗留代码。关于这段代码,我真正知道的是它是在Irix/Sun系统上开发的,这意味着它具有MIPS体系结构。我在使用这段代码时发现的一件相当奇怪的事情是,它有时会调用像endl和set_new_handler这样的函数而没有std::前缀。显然,这会导致编译错误。由于我假设这段代码有时会在某台机器上编译,因此我对盲目添加std::前缀以使其编译有点谨慎,因为它可能会改变行为.那么,是否有一些旧的非ISO编译器允许这段代码编译?或者是否有某种标志可以传递给gcc以允许这段代码工作? 最佳答案
我想使用placement-new在std::aligned_union_t中构造一个任意类型的对象。一旦构造成功,我希望能够取回指向构造对象的指针,而不用单独存储它。通过简单地reinterpret_cast'ingstd::aligned_union_t这样做是否合法,只要我确保将其转换为构造的原始类型?下面的示例代码是否合法?MyStruct是否应该满足任何类型特征要求?例如,它必须是POD吗?#include#include#include#includestructMyStruct{intvalue=0;};constexprsize_tc_alignedUnionSize=
我有一个结构,需要打包(不打包大小为20个字节,但我需要16个才能读/写它)。当我添加packed属性时,我得到了结构的所有成员的error:packedattributeisunnecessaryfor警告。当使用pragma消除错误时,代码可以正常编译并且结构的大小为16,但是如果我删除pragma,它就会失败(因为我使用的是-Werror)。clang只是错误地发出了这个警告还是我做错了什么?#includetypedefstruct__attribute__((packed)){uint16_twFormatTag;uint16_tnChannels;uint32_tnSamp
在Python脚本中,我试图确定安装的Clang支持的最高C++标准。一个问题是我不能依赖clang--version的输出总是相同的——最好的例子是OSX上的AppleClang。尝试使用-std=c++11、-std=c++14等测试标志编译helloworld.cpp文件,...似乎不是最可靠的方法,需要创建临时文件。是否可以运行任何命令来测试某种方言是否可用而无需实际编译任何东西? 最佳答案 Isthereanycommandonecouldruntotestifacertaindialectisavailablewitho
Makeshared使用引用计数和对象的单一分配提高性能,是否可以将自定义分配器与std::allocate_shared一起使用并且仍然有一个分配,根据我写的测试代码它没有发生:sample我知道boost::intrusive,但它有额外的代码需要编写并且可能出错 最佳答案 在一些调试的帮助下发现std::allocate_shared做了预期的事情,它允许你只为你的对象和引用计数器进行一次分配。下面是更正后的代码:allocateshared此处operatornew对std::make_shared和std::allocat
我有以下辅助函数,它接受一个字符串View并在unordered_map中返回一个查找:intScanner::getOpCount(std::string_viewop){autoitr=Parser::opTable.find(op);}//inanotherfile:conststaticstd::unordered_mapopTable;这不会编译,因为find需要一个字符串参数,所以我找到的唯一解决方案(如果我错了请纠正我)是将op包装为字符串{操作}。然而,让我担心的是std::string_view是为了简化字符串传递,但是如果我必须从它构造一个字符串而不考虑函数体,那么
根据ConcurrencyTS,下面的代码会发生什么?autof0=std::async([]{return0;});autof1=f0.then([](auto&f){returnf.get()+10;});autof2=f0.then([](auto&f){if(!f.valid())return;returnf.get()+10;});到第三行代码执行时,f0已经有了continuation,所以根据TS,f0应该抛出异常,中止程序,UB或者有不同的行为?我不清楚。 最佳答案 根据cppreference,它是未定义的:Att
这段代码structBase{};structDerived:Base{usingBase::Base;};intmain(){Baseb;Derivedd{b};}compilesfineonclang++3.9,然而它failsonallgcc's(包括7)和小于3.9版本的clangs错误信息error:nomatchingfunctionforcallto'Derived::Derived()Derivedd{b}'.上面的代码是否合规?PS:如果我注释掉usingBase::Base行,代码将不再在clang-3.9上编译。 最佳答案
std::chrono::system_clock的rep类型必须是有符号算术类型,而steady_clock和high_resolution_clock(和自定义时钟类型)不需要具有签名的rep类型。这种区别的基本原理是什么?使用无符号rep类型的时钟会产生什么后果? 最佳答案 这样做的理由是让供应商在steady_clock上有更多的自由。和high_resolution_clock.事后看来,这种自由并不是必需的,因为迄今为止所有的实现都使用带符号的整数类型。使用未签名的rep的后果在这些时钟中是他们的duration嵌套类型